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(54) System and method for hieraixshica! multicast routing in ATM networks 



(57) The present invention extends the PNNI proto- 
cols to support hierarcliical multicast routing and sign- 
aling for ATM networks. The invention utilizes an exten- 
sion to a core-based tree algorithm. Instead of a single 
core node, core nodes are maintained in each peer- 
group and at each level of the hierarchy. The advantage 
of this is that one single core node is not overloaded. 
Additionally this increases fault-tolerance because 
there are no single points of failure. As would be under- 
stood, the present invention is highly scaleable because 
of the hierarchical nature of PNNI. In addition, the 



scheme supports multiple senders and dynamic mem- 
bership changes to the multicast group. Quality of serv- 
ice requirements can be negotiated during connection 
setup and are guaranteed during the course of the con- 
nection. Though some additional topological informa- 
tion has to be flooded in the peer-groups to compute 
efficient multicast routes, the overheads to the connec- 
tion management are minimal. The multicast tree is built 
incrementally and the cost of the tree is comparable to 
the cost of the Steiner Tree computed using some stand- 
ard heuristics. 
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Description 

Field of Tlie Invention 

The present invention relates generally to multicast 
operations in communications networks, and more par- 
ticularly to a hierarchical multicast routing scheme in an 
ATM network architecture. 

Background of The Invention 

Mullicasling (or poinl-lo-mullipoinl routing) in Asyn- 
chronous Transfer Mode ATM) networks is a mecha- 
nism for sending ATM cells from one source to multiple 
destinations using a single connection. A straightfor- 
ward approach for multicasting would establish point-to- 
point connections from a source to each of the destina- 
tions and the ATM cells would be sent to the respective 
destinations using these connections. This approach 
does not work well, however, for applications like video 
conferencing because such applications require very 
high bandwidth. Moreover, this approach docs not scale 
well, as the number of multicast applications and the 
number of destinations per connection increase. A sig- 
nificant challenge is to develop a highly scaleable 
scheme for multicasting which is also efficient with re- 
spect to a combination of factors like bandwidth con- 
sumption and delay A further challenge Is to guarantee 
some quallty-of-sen/lce (QoS) for each of the connec- 
tions. 

A first step in finding efficient schemes for multicast- 
ing is to define a model for the problem. Networks are 
generally modeled as weighted, undirected graphs. The 
nodes of the graphs represent the switching systems 
and the hosts. Edges, on the other hand, represent the 
physical links. The weight associated with an edge, in 
some way reflects the cost of using the link (in terms of 
delay bandwidth consumption or distance). The prob- 
lem of finding a scheme for multicasting reduces to find- 
ing a subgraph of the network graph satisfying certain 
properties. The subgraph must be atree with the source 
as the root and the destinations as either internal nodes 
or the leaves. As would be understood by a person 
skilled in the art, this tree Is called the Stelner Tree of 
the graph for the given source and destination nodes. 
Minimizing the cost of the Stelner Tree while satisfying 
the QoS constraints results in efficient multicasting. It 
must be noted that the cost of the Steiner tree is the sum 
of the cost of the individual links that are part of the tree. 
It has been shown that finding the optimal Steiner Tree 
is quite a complex problem. But there exist good heu- 
ristics, whose solutions can be bounded by a factor of 
two times the cost of the optimal solution. The problem 
of finding the efficient tree is called the routing problem 
for multicasting. In connection-oriented networks, acon- 
nection has to be established before the ATM cells can 
be transmitted. This is achieved using signaling. The 
problem of efficient connection establishment is termed 



as the signaling problem in ATM networks. 

Multicasting applications can themselves be mod- 
eled in several ways, depending on their degree of com- 
plexity The simplest model, referred to herein as Model 
5 1 , has a single source sending ATM cells to a fixed set 
of destinations. In this case, the Steiner Tree can be 
computed statically before the connection is set up and 
ATM cells can be transmitted along the links corre- 
sponding to edges of the Steiner Tree. 
10 Aslightly more complex model, referred to as Model 
2, can handle dynamic changes to the set of destina- 
tions during the course of the multicast. The destinations 
are addressed collectively by a multicast group address. 
ATM cells designated to the group address are forward- 
's ed to all the destinations that have registered member- 
ship to the group address. Changes in the destination 
set result in the recomputation of the Steiner Tree. 

The above models have only a single user sending 
data to the multicast group. The complexity of the mul- 
20 ticast increases if there are several senders per multi- 
cast group (also known as multipoint-to-multipoint con- 
nection). In this case, there can be a separate Steiner 
tree for each sender However, this would not bo scale- 
able because of the increased complexity of maintaining 
25 information about each Steiner tree. One way of over- 
coming this problem is to associate one tree with the 
multicast group. One node in the tree, called the core 
node. Is chosen to receive the ATM cells from all send- 
ers. The core node Is then responsible for sending the 
30 cells to all the destinations in the tree. Though this 
scheme is scaleable, the main problem here is the over- 
loading of the core node, which leads to performance 
degradation. 

35 IWultlcast Routing in The Internet 

In connectionless networks like the Internet, the 
multicasting problem is slightly simplified because there 
is no additional overhead of connection setup and man- 

40 agement. But, QoS requirements are hard to guarantee 
because connectionless networks provide only best-ef- 
fort services. Protocols like RSVP (Resource reSer\fe- 
tion Protocol) provide the means to reserve resources, 
but implementation of such a scheme is not yet practical. 

45 In connectionless environments like the Internet, 
several approaches for multicasting have been pro- 
posed in the prior art. The simplest approach is termed 
flooding or truncated broadcast. Here, packets are 
flooded to all routers in the network and the routers have 

50 the responsibility of multicasting the packets within their 
local subnets. Duplicate packets are discarded by each 
router. If a "shortest-path" criterion is used to decide 
which packets to flood and which packets to discard, the 
resulting scheme is called Reverse-Path Flooding 

ss (RPF). The flooding mechanism is inherently based on 
the hop-by-hop routing scheme in the connectionless In- 
ternet. The main disadvantage with flooding is that sev- 
eral redundant packets are transmitted on the links. For 



Patent provided by Sughrue Mion, PLLC - http://vifww.sughriie.com 



3 

high bandwidth video applications, this can lead to con- 
gestion in the network, especially when routers have to 
maintain a separate tree for each sender of a multicast 
group. 

The idea of a Core-Based Tree (CBT) requires the 
maintenance of only one tree per multicast group. Each 
multicast group has a core node associated with it. This 
node is always a part of the multicast tree for that group. 
A node which wants to receive packets sent to that 
group must register with the core node. The core node 
forms a multicast tree with all the destination nodes. 
When a source wants to send packets to the group, it 
first sends a packet towards the core node. If any of the 
intermediate nodes is already on the multicast tree, it 
then forwards the packet on the links of the multicast 
tree. The main advantage here is that only one tree is 
maintained per multicast group which makes it very 
scaleable. On the other hand, if there are many senders 
and all of them send the packets to the core node, then 
the core node can be a bottle-neck. The core node is 
also the single point of failure, hence this algorithm is 
not fault-tolerant. 

Many of the schemes in the prior art for multicasting 
are designed for the connectionless model of the Inter- 
net. In future, the Internet will be based on the connec- 
tion-oriented native ATM networks. Thus, schemes for 
multicasting in the ATM networks need to be developed. 
Several higher layer multicasting applications have 
been envisaged with underlying ATM networks. One 
such application by lETF's IP-over-ATM working group 
(IPATM) maps the connectionless IP multicast service 
over native ATM networks. The scheme uses the con- 
cept of a Multicast Address Resolution Sewer (MARS). 
All the nodes that want to be members of a particular 
group register with the MARS. To send data to the mul- 
ticast group, two schemes have been proposed. In the 
multicast server scheme, there is a multicast server as- 
sociated with each multicast group and there may be 
more than one server to take care of load balancing and 
fault-tolerance. The multicast servers also register with 
the MARS. The sender contacts the MARS and gets the 
identity of the server where the MARS then establishes 
connection with the server The server has a point-to- 
multipoint connection with all the destination nodes and 
Is responsible for transmitting the data to all the desti- 
nations. New destinations also contact the MARS and 
then join the sen/er's point-to-multipoint connection. In 
the absence of a multicast server, the MARS returns the 
list of all the destinations to the sender The sender then 
sets up a point-to-multipoint connection with all the des- 
tinations. This scheme assumes the existence of an un- 
derlying point-to-multipoint protocol for native ATM net- 
works. 

Other applications like video-conferencing require 
the underlying system to support multicasting while 
guaranteeing certain quality of service like consistent 
bandwidth, bounded delays and bounded delay-jitter. It 
is not easy to provide end-to-end guarantees and quality 
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of service when a hop-by-hop routing mechanism is 
used. This is the main motivating factor for developing 
protocols for multicasting in ATM networks. 

s Routing and Signaling in ATiVI Networl<s 

Routing and signaling are two main components in 
the design of a connection-oriented protocol. Routing 
protocols help in the computation of an efficient path for 
10 the specific connection. Signaling protocols assist in ef- 
ficient establishment and management of the connec- 

A signaling mechanism handles set-up, mainte- 
nance and clearance of connections between a source 

15 and possibly more than one destination. During connec- 
tion setup, the resources on the links are also reserved 
so that quality of service(QoS) can be guaranteed for 
the connection. The ATM Forum has proposed ATM UNI 
Signaling mechanisms at the user network interface. 

20 The basic point-to-point signaling protocol is a two- 
way hand-shaking mechanism. Some signaling mes- 
sages arc global in nature, that is, they are propagated 
from the source end to the destination end. Local ac- 
knowledgment messages are used to acknowledge the 

25 receipt of global messages as they pass from one node 
to another in the network. The source (which is an ATM 
end-system) sends a SETUP message to the switching 
system over the User-Network Interface. This message 
includes information like destination address and the 

30 QoS requirements. The network forwards the SETUP 
message towards the switching system to which the 
destination end-system is attached. Resources are re- 
served en route to guarantee QoS requirements. 
When the SETUP message reaches the destina- 

35 tion, the destination can either accept the connection or 
reject it for any one of various reasons. For example, 
one important reason could be that QoS guarantees 
cannot be fulfilled. If the connection is rejected, a RE- 
LEASE message is sent from the destination which 

40 propagates back to the source, where all the resources 
that were previously reserved are released. If the con- 
nection is accepted, a CONNECT message is sent from 
the destination which propagates through the network 
to the source. This ends the connection establishment 

45 phase of the signaling mechanism. Additional signaling 
messages are then required to maintain this connection. 
The entire signaling protocol can be represented by a 
state diagram for each participant of the protocol. When- 
ever a node sends or receives a message, a transition 

50 Is made from one state to another 

The basic point-to-multipoint connection is a tree- 
based model with a root and several leaves. The con- 
nection is initiated with the establishment of a point-to- 
point connection from the root to one of the leaves. The 

55 address of the root node forms a part of the connection 
identification. Additional connections to other leaves are 
established by sending an ADD-PARTY signaling mes- 
sage to each of the leaves. Dynamic membership is sup- 
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ported in two ways. In the root-initiated join mectianism, 
the root sends the ADD-PARTY message to a leaf that 
is interested in joining the multicast connection. The leaf 
responds with a CONNECT message to indicate suc- 
cess of the connection. 

In the leaf-initiated join(LIJ) mechanism, the root in- 
itiates a connection with LIJ options. The leaf indicates 
the willingness to join the multicast connection by send- 
ing a LEAF-SETUP-REQUEST message to the net- 
work. Since the network is aware of the LIJ connection, 
It sends a SETUP message to the leaf. Successful con- 
nection establishment Is Indicated when the leaf sends 
a CONNECT message to the network. Depending on 
the protocol, the network may or may not notify the root 
about the identity of the joined leaf. Similar mechanisms 
are available to drop a leaf node from a particular con- 
nection. 

The current UNI signaling mechanisms do not, how- 
ever, address the issue of the establishment of a 
multipoint-to-multipoint connection. One way of imple- 
menting this type of connection is to use a peer-to-peer 
model. In this model, there is no root node and all the 
participating nodes have similar functions. Some partic- 
ipants are senders or receivers alone, while others are 
both. The group is then logically identified by a multicast 
group address. 

Private Node-Network Interface (PNNI) 

The routing of the signaling messages between 
ATM switches uses the NNI (Node-Network Interface) 
protocol. The main difference between UNI and NNI pro- 
tocols is that NNI protocols have to incorporate routing 
as well as signaling. The signaling component of the NNI 
protocol Is used to relay connection requests through 
the ATM network. The routing component of the NNI 
protocol determines the route used by the signaling 
messages to propagate through the ATM network. The 
connection is also established on this route and subse- 
quently the data also flows through this route. The rout- 
ing of signaling messages is similar to a connectionless 
routing protocol because no connection exists before 
connection setup. 

To ensure inter-operability among various ATM 
switches developed by different vendors, the ATM Fo- 
rum has proposed a NNI protocol called the Private 
Node-Network Interface protocol. PNNI protocols are 
based on link-state routing protocols like the OSPF pro- 
tocols. The protocol model provides a hierarchical view 
of the ATM network. In this model, the hierarchical graph 
consists of nodes and links. An example PNNI Architec- 
ture 10 Is shown in Figure 1. At the lowest level 104 of 
the hierarchy the nodes 12 of the graph represent the 
physical switching systems. The links 14 at the lowest 
level 104 represent physical links that connect the var- 
ious switching systems. At higher levels 80, 64, the 
nodes 1 6, 1 8 are logical nodes, where each logical node 
1 6, 1 8 represents a collection of nodes at the lower level 
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of hierarchy. Similarly, a link 20 between two logical 
nodes is a logical link that represents connectivity be- 
tween the sets of nodes represented by the logical 
nodes. Nodes at each level are grouped together to form 

s Peer Groups 22, 24, 26 (represented by ellipses in Fig. 
1). Each peer-group has a peer-group leader (PGL). In 
Figure 1 , the PGLs for peer groups 22, 24, 26 are rep- 
resented by dark nodes 32, 34, 36. A PGL has the ad- 
ditional functionality of representing the peer-group as 

'0 a logical node at the higher level of the hierarchy At the 
lowest level 1 04, the links 28 that connect nodes belong- 
ing to different peer groups are called border links. The 
nodes on either side of a border link are called border 
nodes. For example, in Figure 1 , nodes A.2.4 and A.3.2 

1S are border nodes. 

Similar to OSPF efficient routes can be computed 
only by collecting information about states of the nodes 
and the links in the network. This information constitutes 
the topology information of the network. The link state 

20 includes information like the available bandwidth, the 
mean delay on the link and the peak cell rate that can 
be supported by the link. The node state includes ag- 
gregate information about the peer-group and the end 
systems attached to the switching system. Each node 

2S periodically floods the topology state information within 
its peer-group. Other nodes that belong to the peer- 
group update their databases with this information. 
Thus, each node In the peer-group has accurate Infor- 
mation about the node and link states of all the topology 

30 elements within the peer-group. The PGL aggregates 
the information of the peer-group and floods this aggre- 
gated information in the higher level peer-group. Simi- 
larly, the PGL also collects aggregated information 
about other peer-groups through their respective PGLs. 

35 The PGL floods this collected information in the lower 
level peer-group. Thus, every node in the lower peer- 
group updates its database with the aggregated Infor- 
mation about the nodes in the other peer-groups. The 
maintenance of this Information is not very difficult even 

40 for large networks because only the aggregated Infor- 
mation is stored in the nodes. This makes the PNNI pro- 
tocol highly scaleable to large networks. The same pro- 
tocol is followed by the nodes at each layer of the hier- 
archy, hence the protocol is termed as recursive. 

45 The point-to-point routing protocol as specified cur- 
rently is source-based routing. The source has complete 
information about all the nodes and links within Its peer- 
groups, but it has only aggregated information about the 
nodes and links in other peer groups. The source cannot 

50 determine the exact route to the destination node. 
Based on the information available to it, the source com- 
putes a logical path to the destination node. This path 
can involve logical nodes from higher layers of the hier- 
archy. The actual route at each level of the hierarchy is 

55 determined during the setup of the connection. The 
route depends on the QoS requirements of the connec- 
tion. Signaling messages are used to establish the con- 
nection and negotiate QoS requirements. 
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PNNI Signaling 

Signaling is the mechanism by which the connec- 
tion is set up in a connection-oriented protocol. The sig- 
naling incorporates functions like resource reservation, 
virtual channel/path establishment and QoS negotia- 
tions. In PNNI, the signaling mechanism is similar to 
ATM UNI Signaling, however, PNNI incorporates addi- 
tional information like the Designated Transit List (DTL), 
which represents the approximate route for setting up 
the connection. The DTL is a set of paths, one for each 
level of hierarchy. At the lowest level of the hierarchy 
the path is a physical path between two nodes within a 
peer-group. At higher levels of hierarchy, the paths are 
logical paths. Within a peer-group, the SETUP message 
traverses along the designated path, until it reaches a 
border node. This border node is called the exit border 
node or the egress node. The edge linking the border 
nodes of the two peer-groups is represented as a logical 
link at a higher layer. If this logical link is present in the 
DTL, the SETUP message is passed to the neighboring 
peer-group across the border link. The border node in 
the neighboring peer-group is called the entry border 
node or the ingress node. If the destination node is in 
this peer-group, the ingress node computes the path to 
the destination node and appends it to the DTL. Other- 
wise the ingress node computes the path to the border 
node which has a link to the peer-group that Is on the 
path to the destination node. The computed path is ap- 
pended to the DTL. The ingress node also stores this 
path information until the connection is set up. Only the 
source node and the ingress nodes can add paths to the 
DTL. This is important during crankback because it can 
prevent looping and unnecessary repeated exploration 
of failed paths. 

Crankback occurs if a node on the pre-determined 
route is not able to find a path through its peer-group. 
This could be because of node or link failures or strin- 
gent QoS requirements. This node then informs the in- 
gress node of the peer-group that it cannot find a path. 
The ingress node can then try alternate routes to reach 
the destination. The signaling mechanism stops once 
the destination node is reached or no path is available. 
If no path is available, the connections setup so far are 
cleared. If the destination node accepts the connection, 
a CONNECT message Is sent from the destination to 
the source along the established path (in the reverse 
direction). This enables all the ingress nodes to clear all 
the route information, which they have stored to assist 
crankbacks. 

Phase 1 of the PNNI protocol deals primarily with 
point-to-point routing and signaling. Phase 2 of the PNNI 
protocol will deal with point-to-multipoint routing. Some 
work has been done in the prior art in this area by F.G. 
Liaw, ATM Group Multicast Routing and Signaling Pro- 
tocol: Architecture Overview, ATM Forum draft 94-0995, 
1 994, wherein the idea of a core based-tree with multiple 
core nodes is mentioned. Although the idea of multiple 



core nodes is presented here, this paper does not pro- 
vide the details of the routing and signaling mechanisms 
in a hierarchical framework Accordingly, there is a need 
to develop a highly scaleable scheme for multicasting 
5 in a hierarchical framework which is also efficient with 
respect to a combination of factors like bandwidth con- 
sumption and delay, while guaranteeing some quality- 
of-sen/ice (QoS) for each of the connections. 

10 Summary of the Invention 

The invention is set out in the independent claims. 
Preferred forms are set out in the dependent claims. 
A method according to the invention may further in- 

15 elude attaching a non-core node wanting to join said 
multicast group to said core node within its peer group, 
wherein said core node joins the core node of a parent 
peer-group on said multicast tree in a recursive fashion 
if said core node is not part of said multicast tree. 

20 A non-core node leaving said multicast tree may re- 
move itself and remove the edge nodes between said 
non-core node and its neighbor, and a core node with 
no destination nodes in its poor group leaving said mul- 
ticast tree may be required to prune itself therefrom. 

2s The method may further include the steps of: send- 
ing a SETUP message from a node wanting to join said 
multicast group towards a core node within its peer 
group; and reserving resources on a link for a connec- 
tion, when a SETUP message passes on said linkfrom 

30 one node to another, a path to said core node being ex- 
pressed in terms of a designated transit list (DTL), where 
said DTL is an approximate path to be followed by sig- 
naling messages. Said DTL created by a source may be 
able to be modified by an ingress node to the peer- 

35 group, an egress node to the peer-group and a core 
node of the peer-group. The method may further include 
sending a RETRACE message, wherein said RE- 
TRACE message traverses only on links already tra- 
versed by a SETUP message in an opposite direction. 

40 The method may further include sending a CONNECT 
message, wherein said CONNECT message is sent by 
a node to which a joining node attaches, said CON- 
NECT message traversing on all the links on which re- 
sources are resen/ed. The method may further include 

45 sending a RELEASE message, wherein said RELEASE 
message may be sent by any intermediate nodes, in 
case a connection cannot be established, said RE- 
LEASE message also being sent to terminate a connec- 
tion, wherein said RELEASE message traverses on all 

50 the links on which resources are reserved. Upon receiv- 
ing said SETUP message, if the node is not on the mul- 
ticast tree, said node may check the DTL and forward a 
message to a next node in the DTL with a pointer where- 
in if said node is an egress border node, said node saves 

55 a list of the nodes visited by said SETUP message and 
forwards said list across a border link, and wherein if 
said node is an ingress border node, said node com- 
putes a path to a core node of the peer-group, said path 
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being converted to a new DTL and pushed onto a stack, 
wherein said SETUP message is then forwarded ac- 
cording to the new DTL towards the core node. Upon 
receiving said SETUP message, if the node is a core 
node, said core node may first checl< if it is active, where- 
in if not active, said core node computes a path to a next 
peer-group In the DTL, wherein said path is converted 
to a new DTL and pushed onto a stack, and wherein if 
any node on said path has already been visited by said 
SETUP message, said SETUP message Is changed to 
a RETRACE message. Entries in the DTL may be re- 
moved until a first entry on the top of said slacl< is a vis- 
ited node and no other entry in the DTL is a visiled node, 
said RETRACE message being forwarded towards a 
node from which said SETUP message was received, 
wherein If there are no visited nodes In said path, said 
SETUP message Is forwarded as persaid new DTL. Up- 
on receiving said SETUP message, If a core node is not 
active and the DTL stack Is empty, said core node may 
forward said SETUP message towards a core node of 
a parent peer-group, wherein a path to a core node of 
said parent peer-group and a corresponding new DTL 
is computed and a check for a visited node Is made, 
wherein if a visited node Is found, said SETUP message 
is changed to a RETRACE message and the DTL Is 
modified, and wherein if no visited nodes are found, the 
SETUP message is forwarded as per the new DTL. Up- 
on receiving a RETRACE message. If a first entry on top 
of the DTL stack does not match with a node ID or an 
ancestor ID, the RETRACE message may be forwarded 
towards a node from which It received the SETUP mes- 
sage, wherein If the entry matches, a path to a next entry 
as per the DTL is computed, a check for visited nodes 
being made, wherein If there Is a visited node, the DTL 
Is modified and the RETRACE message Is forwarded 
towards the node from which it received the SETUP 
message and If there Is no visited node, the RETRACE 
message Is changed to a SETUP message and forward- 
ed to the next node as per the new DTL, For said CON- 
NECT message, resources that are reserved on a link 
may be committed, the node forwarding said message 
on all the links on which a SETUP was received, with 
the exception of a link on which said CONNECT is re- 
ceived. For said RELEASE message, resources that are 
reserved on a link may be released, the node forwarding 
said message on all the links on which a SETUP was 
received/sent, with the exception of a link on which said 
RELEASE message Is received. 

The communications network may be an ATM net- 
work and said cells ATM cells. 

The present invention extends the PNNI protocols 
to support hierarchical multicast routing and signaling 
for ATM networks. The invention utilizes an extension 
to a core-based tree algorithm. Instead of a single core 
node, core nodes are maintained in each peer-group 
and at each level of the hierarchy. The advantage of this 
Is that one single core node is not overloaded. Addition- 
ally, this increases fault-tolerance because there are no 
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single points of failure. As would be understood, the 
present invention Is highly scaleable because of the hi- 
erarchical nature of PNNI, in addition, the scheme sup- 
ports multiple senders and dynamic membership 

5 changes to the multicast group. Quality of service re- 
quirements can be negotiated during connection setup 
and are guaranteed during the course of the connection. 
Though some additional topological information has to 
be flooded in the peer-groups to compute efficient mul- 

10 ticast routes, the overheads to the connection manage- 
ment are minimal. The multicast tree is built Incremen- 
laiiy and the cost of the tree is comparable to the cost 
of the Stelner Tree computed using some standard heu- 
ristics. 

'5 In one embodiment of the invention, a method is set 
forth for multicasting cells in a communications network. 
The communications network Includes a plurality of 
nodes coupled to one another by links and comprises 
the steps of: dividing the communications network into 

20 a hierarchical arrangement of peer groups, wherein a 
peer group includes at least one of the nodes therein; 
building a multicast tree for a multicast group which In- 
cludes all participant nodes, wherein a participant node 
is either a sender or receiver of data for the multicast 

25 group. The step of building including the steps of: se- 
lecting core nodes for each of the peer groups within the 
multicast group, wherein a node wanting to become part 
of the multicast group must register with the core node 
in Its peer group; and flooding core node information \o- 

30 cally within each of the peer groups, wherein the nodes 
of a peer group need only maintain information about 
the core nodes of direct ancestor peer groups. Cells are 
able to be efficiently multicast by way of said multicast 
tree to said nodes in said multicast group, A peer group 

35 leader Is selected for each of the peer groups in the net- 
work for aggregating topology information of nodes In 
the peer group and flooding the topology information in 
higher level peer groups, wherein a list of logical core 
nodes of ancestor peer groups Is flooded In a peer group 

40 by each said peer group leader. 

Brief Description of The Figures 

For a better understanding of the present invention, 
45 reference may be had to the following description of ex- 
emplary embodiments thereof, considered In conjunc- 
tion with the accompanying drawings, in which: 

FIG. 1 shows an illustration of a multicast tree within 
50 a PNNI Architecture and In accordance with the 
present Invention; 

FIG. 2 shows an illustration of a multicast tree In 
accordance with the present invention after a node 
joins the multicast tree; 
ss FIG. 3 shows an Illustration of the multicast tree af- 
ter a first and second node join; 
FIG. 4 shows an Illustration of a multicast tree after 
a node leaves the multicast group; and 
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FIG. 5 shows an illustration for an exemplary archi- 
tecture for signaling in accordance with the present 
invention. 

Detailed Description 

The present invention describes a methodology for 
multicast routing in the PNNI framework. The scheme 
is highly scaleable to iarge networks because routers 
have to maintain oniy one tree per multicast group. The 
method supports dynamic membership to a muiticast 
group, in that, nodes can join or leave the muiticast 
group during the course of the multicast. Muitipie send- 
ers to the multicast group are also supported, which en- 
ables reaiization of a true multipoint-to-multipoint con- 
nection. In addition, the multicast tree can be dynami- 
cally changed to reflect changes in the node and link 
states. The invention also has very low latency, that is, 
the join time of a new node is significantly small. 

The present invention utilizes an extension of a core 
based tree (CBT) methodology to accomplish the mul- 
ticast routing. One of the drawbacks of CBT algorithms 
of the prior art is that the core node becomes a bottle- 
neck and a single point of failure. To overcome this draw- 
back, the present invention uses more than one core 
node per muiticast group. In the PNNi framework, intro- 
duction of a core node in each of the peer-groups that 
is within the scope of the multicast results in a highly 
modular algorithm. Logical core nodes are also intro- 
duced at higher levels of the hierarchy Using these core 
nodes, a multicast tree is built to include all the partici- 
pant nodes, wherein a participant node is either a send- 
er or a receiver of data for the multicast group. The se- 
lection of core nodes is very crucial because a wrong 
set of core nodes can adversely affect the performance 
of the algorithm. Although the study of various schemes 
for core node selection is beyond the scope of the 
present invention, some criteria has been included 
which will help in determining good candidates for the 
core node. 

Core Node Selection 

When a multicast group is set up, the core nodes 
for that group are also selected, wherein each group has 
its own set of core nodes. To compute efficient multicast 

trees, it is important to have the right set of core nodes. 
Border nodes are good candidates for core nodes, in- 
tuitively, this makes sense because border nodes are 
more likely to be a part of the multicast tree. Nodes with 
larger degree also make better core nodes. Since core 
nodes have to handle high bandwidth, it is clear that 
nodes without sufficient bandwidth are poor choices as 
core nodes. It cannot be proven that one of these criteria 
is more important than the other, however, a border 
node with a large degree and sufficient bandwidth 
seems to be the best choice as a core node. As would 
be understood, care must be taken so that the same 



nodes do not get selected as the core nodes for several 
multicast groups, as heavily loaded core nodes will ad- 
versely affect performance. 

Once the core nodes are selected, core node infor- 

5 mation is flooded locally within each peer-group. A list 
of logical core nodes of ancestor peer-groups is also 
flooded by the peer group leader (PGL). The amount of 
information flooded is minimal because the nodes of a 
peer-group need not maintain the information about 

TO core nodes of peer-groups that are not direct ancestors. 
This flooding can be incorporated along with the flooding 
of topoiogy slate information Once selected, it is as- 
sumed that core nodes will not change, however as 
would be understood, this restriction is not binding. 

IS In the present invention, a core node is defined to 
be active if there is a participant node in the same peer- 
group to which the core node belongs. The present in- 
vention requires that the following conditions be met at 
all times: all active core nodes must be on the multicast 

20 tree; if there is an intermediate (non-participant node 
which is on the multicast tree) node belonging to a par- 
ticular poor-group, tho corresponding core node must 
be on the muiticast troc; and if there is no participant 
node in a particular peer-group, the corresponding core 

25 node and intermediate nodes of that peer-group must 
be pruned from the multicast tree, provided it does not 
disconnect the tree. These conditions result in a well- 
balanced tree and addition and deletions of participant 
nodes can be done with minimal latency 

30 

Participant-Initiated Join (PIJ) 

In the participant-initiated join (PIJ) mechanism, 
when a node wants to join the multicast group (referred 

35 as joining node), the joining node tries to attach to the 
core node within its peer-group. The shortest path to the 
core node can be easily determined because the node 
and link states within the peer-group are completely 
known to all nodes in the peer-group. A setup message 

40 is sent to the core node along this shortest path. En 
route, if the message reaches a node that is already on 
the multicast tree, the joining node attaches to this par- 
ticular node and becomes a part of the multicast tree. 
It can happen that the core node in the peer-group 

45 of the joining node is not currently on the multicast tree. 
The core node then tries to join the core node of the 
parent peer-group. The routing is recursively followed 
at each level of hierarchy until an active core node or 
the core node of the topmost peer-group is reached. 

50 This results in the building of a backbone tree consisting 
of active core nodes. The joining node along with all the 
involved core nodes then becomes a part of the multi- 
cast tree. 

The PIJ mechanism of the present invention can be 
ss further explained with reference to Figure 1. Figure 1 
depicts a hierarchical network 1 0 in accordance with the 
present invention, wherein the dark nodes are repre- 
sentative of core nodes. A multicast tree is shown, 
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wherein initially the nodes A, A.2 and A.2.1 are on the 
multicast tree. When node A.3.5 wants to join the mul- 
ticast tree, It first joins the core node within its peer- 
group 23, that is, node A.3.1 . Since A.3.1 Itself Is not on 
the multicast tree, the algorithm is recursively executed 
at the next higher level 80 resulting in the node A.3 join- 
ing the core node A.2. The resulting tree 40 Is shown In 
Figure 2. Now, if node B.2.5 wants to join the multicast 
group, it first joins node B.2.1. At level 80, B.2 joins 8. 
1. Let the logical link (B.2-B.1) be represented by the 
physical link (42) B.2.2-B. 1 .4. At level 1 04, the physical 
path (B.2.1, B.2.2, B.1.4,B.1.1) is appended to the mul- 
ticast tree. Since B.I itself is not on the tree, the node 
B at level 64 joins node A. Let the logical link (B-A) be 
represented by the logical link B.I .2~A.3.4. This results 
in the path (B.1.1,B.1.2,A.3.4) being appended to the 
multicast tree. The resulting tree 50 Is shown in Figure 
3. Nodes B.1.3 and B.1.5 can easily join the multicast 
group by attaching to nodes B. 1 .2 and B. 1 .4 respective- 
ly. Thus, the latency of joining Improves significantly In 
this algorithm. 

Deletion of Nodes 

In describing the deletion of nodes from a multicast 
group, let the multicast tree which connects all the par- 
ticipant nodes and the active core nodes be considered 
as a graph. When a participant node, whose degree Is 
more than 1 , tries to leave the multicast group, It remains 
on the multicast tree as an Intermediate node. When a 
participant node, whose degree Is 1 , tries to leave the 
multicast group, It prunes Itself from the tree, provided 
it is not a core node. This pruning can result In the de- 
gree of the neighbor node to become 1. The neighbor 
node then prunes itself, if it is neither the core node nor 
a participant node. This process is repeated, resulting 
in a cascade of prunes. The cascade continues until a 
participant node or a core node or a node with degree 
more than 1 is reached. 

Whenever a participant node leaves the multicast 
group, the core node in that peer-group Is also informed. 
If the core node finds that there are no more participant 
nodes within Its peer-group, it can delete Itself from the 
multicast tree, provided It does not disconnect the tree. 
This Is done at the logical level as well. The deletion of 
a logical link results In some physical nodes also being 
deleted. The pruning keeps the cost of the tree within 
reasonable limits, especially when there are few partic- 
ipant nodes. 

Referring to FIG. 4, an example is shown with par- 
ticipant nodes B.2.5, B.1.3, B.1.5 and A.3.5 for the de- 
letion of nodes in the multicast of network 1 0, As can be 
seen, if node B.2, 5 wants to leave the multicast group, 
the nodes B,2.5 and B,2.4 get pruned. At level 80, node 
B.2 finds that there are no participant nodes within the 
peer-group it represents. So, node B.2 prunes itself, re- 
sulting In nodes B.2.1 and B.2.2 pruning themselves 
from the multicast tree. The resulting tree 60 Is shown 
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In Figure 4. Now if B.2.5 wants to rejoin the multicast 
group and the link states have changed, a different path 
may get appended to the existing tree. This dynamic 
creation of tree helps in satisfying the QoS requirements 
5 of the connection under varying node and link states. 

Signaling Mechanisms 

In order to add a node to an already existing multi- 
10 cast tree some sort of signaling mechanism is needed. 
In one embodiment of the present invention, a peer-to- 
peer implementation is described, however as would be 
understood by those skilled in the art, other ways of im- 
plementing the instant routing algorithm are available. 
15 In the peer-to-peer scheme, the multicast group is rep- 
resented by a logical multicast address. All the nodes 
Interested In the multicast group are participant nodes. 
There are no root or leaf nodes. The node that wants to 
join the multicast group sends a SETUP message to- 
20 wards the core node within Its peer-group. The path to 
the core node is expressed in terms of a Designated 
Transit List (DTL): as has boon explained with respect 
to PNNI Signaling, and as would be understood by a 
person skilled in the art. This is a point-to-point mecha- 
25 nism in the sense that one branch is usually added to 
the existing multicast tree. Since core nodes are in- 
volved, It can happen that core nodes also get added to 
the tree as additional branches. Addition of more than 
one branch to add a single node Is a distinct feature of 
30 the present Invention. 

The basic types of messages for the signaling 
mechanism of the present Invention are a SETUP mes- 
sage, RETRACE message, CONNECT message, and 
RELEASE message. The SETUP message originates 
35 at the joining node to set up a connection. The destina- 
tion for this message is either a node on the multicast 
tree or the core node in the peer-group. When this mes- 
sage passes on a link from one node to another, re- 
sources for the connection are reserved on that link. 
40 This message carries the Designated Transit List (DTL), 
which is the approximate path to be followed by the sig- 
naling messages. This path is computed by the source 
of the message In source-based routing. In the present 
Invention, the DTL created by the source can be modl- 
45 fled by an ingress node to the peer-group, an egress 
node to the peer-group and a core node of the peer- 
group. Note that this is very different from the PNNI sig- 
naling where only the source and the ingress node can 
modify the DTL. 
50 The RETRACE message is a new type of message 
that has information similar to the SETUP message. A 
key difference, however, is that no resources are re- 
served on the links. Further, the RETRACE message 
traversesonly on the links already traversed by the SET- 
55 UP message, and In the opposite direction. 

The CONNECT message is sent by the node to 
which the joining node attaches. Note that this node 
must already be a part of the multicast tree. The mes- 
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sage traverses on all the links on which resources are 
reserved. When a node receives the CONNECT mes- 
sage, it updates its routing tables to indicate the setting 
up of the connection. 

The RELEASE message can be sent by any of the 
Intermediate nodes, In case the connection cannot be 
established, or to terminate the connection. This mes- 
sage also traverses on all the links on which resources 
are reserved. The resources are released upon receipt 
of this message. 

Upon receiving a particular message, the actions 
taken by a node depend on the type of the message. 
For instance, with the SETUP message, if the node Is 
already on the tree, that node sends a CONNECT/RE- 
LEASE message to the joining node, depending on 
whether the connection is accepted/rejected. The mes- 
sage follows the reverse path to the joining node. 

If the node is not on the multicast tree, it checks the 
DTL and forwards the message to the next node In the 
DTL and also fonwards the pointer. If the node is an 
egress border node. It saves the list of the nodes visited 
by the SETUP message and forwards the message 
across the border link. If the node Is an ingress border 
node. It computes the path to the core node of the peer- 
group. The path Is converted to DTL format and pushed 
onto the stack. The SETUP message Is then forwarded 
according to the new DTL (towards the core node). 

If the node is a core node, it first checks if It is active. 
If it is, then it has to be on the tree, wherein this case 
has been discussed above. If It is not active, the core 
node computes the path to the next peer-group in the 
DTL. This path Is converted to a DTL and pushed on to 
the stack. If any node on this path has already been vis- 
ited by the SETUP message (this can be found out using 
the list of visited nodes), the SETUP message Is 
changed to a RETRACE message. The entries In the 
DTL are removed until the first entry on the top is the 
visited node and no other entry In the DTL Is a visited 
node. The RETRACE message is forwarded towards 
the node from which the SETUP message was received. 
If there are no visited nodes In the computed path, the 
SETUP message is forwarded as per the new DTL. 

If the core node is not active and the DTL stack is 
empty, the core node forwards the SETUP message to- 
wards the core node of the parent peer-group. The path 
to this core node and the corresponding DTL Is comput- 
ed. Again, a check for a visited node is made. In case a 
visited node Is found, the message Is changed to a RE- 
TRACE and the DTL is modified as explained above. If 
no visited nodes are found, the SETUP message is for- 
warded as per the new DTL. 

In the case of the RETRACE message, If the first 
entry on top of the DTL stack does not match with the 
node ID or its ancestor ID, the RETRACE message is 
fonwarded towards the node from which it received the 
SETUP message. 

If the entry matches, the path (and the new DTL) to 
the next entry as per the DTL Is computed. Again; a 
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checkfor visited nodes is made. If there Is a visited node, 
the DTL is modified as explained above and the RE- 
TRACE message is forwarded towards the node from 
which it received the SETUP message. If there Is no vis- 
s ited node, the RETRAC E message is changed to a SET- 
UP message and forwarded to the next node as per the 
new DTL. 

For the CONNECT/RELEASE message, the re- 
sources reserved on the link are committed/released. 

10 The node forwards this message on all the links on 
which a SETUP was received/sent, except the link on 
which this CONNECT/RELEASE is received. It must be 
noted that this message traverses on all the links tra- 
versed by the SETUP message, but In the opposite di- 

15 rection 

A Signaling Example 

Referring to Figure 5, an exemplary illustration of 
20 the present invention signaling mechanism Is shown uti- 
lizing network 200. As shown in Figure 5, dark nodes 

are representative of core nodes. In this example, as- 
sume that node B.1.1 Is already on the multicast tree. 
Now, if node A.3.4 wants to join the multicast group. It 

25 first sends a SETUP message towards the core node In 
its peer-group (node A.3. 1 ). The SETUP message Is for- 
warded to node A.3.1. Since node A. 3.1 Is not active 
and the DTL stack Is empty, the node tries to join the 
core node A. 1 of the parent peer-group. Let the path to 

30 core node A.I be through peer-group A.4. The DTL for 
the path looks like: 

(A.3.1, A.3.2) pointer 1 
(A. 3, A.4, A, 1) pointer 1 

35 

Along with the DTL, a list of nodes visited by the 
SETUP message In the current peer-group Is also 
passed along. This Is used by the ingress, egress and 
the core node to determine loopless paths. 

40 The SETUP message is forwarded to node A.3.2. 
Since node A.3.2 is an egress node, it remembers the 
list of visited nodes (namely, nodes A.3.4, A.3. 1 and A. 
3.2). It then forwards the SETUP message across the 
border link 204 to node A.4.4. Since A.4.4 is an ingress 

45 border node, it computes the path to its core node (node 
A.4.2). Let this path be through A.4.1 . The DTL here is 
as follows : 

(A.4.4, A.4.1, A.4.2) pointer 1 
50 (A.3, A,4, A,1) pointer2 

The SETUP message Is forwarded to node A.4.2 
through A.4.1 . Since A.4.2 is a core node that Is not ac- 
tive and the DTL stack is not empty it computes a path 
55 to peer-group A.I . Let this path go through node A. 4.3. 
The DTL now looks like : 

(A.4.2, A. 4.3, A.4.4) pointer 1 
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(A. 3, A.4, A.I) pointer 2 

Since node A.4. 4 has already been visited by the 
SETUP message, the message type is changed to a 
RETRACE message and the DTL is changed as follows: 

(A. 4. 4) pointer 1 

(A. 3, A.4, A.I) pointer 2 

The RETRACE message is forwarded to the node 
from which the SETUP message was received (node A. 
4.1) and then to A.4. 4. Now the first entry on top of the 
stacl< matches the node ID. Accordingly a path to peer- 
group A. 1 is computed. Since node A.4.4 itself is an 
egress border node, there is no visited nodes in the path. 
So, the RETRACE message is changed to a SETUP 
message and forwarded across the border link to node 
A.1.4. Since A.I. 4 is an ingress node, it finds the path 
to its core node. The DTL now looks like: 

(A. 1.4,A. 1.1) pointer 1 
(A. 3, A.4, A.I) pointer 3 

When A. 1 . 1 receives the SETUP message, the DTL 
stack becomes empty Since node A. 1.1 is not active, it 
forwards the SETUP message to the core node of its 
parent peer-group (node A.I). Since we are already in 
peer-group A.I, the SETUP message is forwarded to 
the core node in its parent peer-group (node B). The 
path to peer-group B is computed. Let the path go 
through peer-groups A.2, A.3 and A.5. The DTL for this 
path is: 

(A. 1.1, A. 1.2) pointer 1 
(A.1,A.2, A.3, A.5) pointer 1 
(A,B) pointer 1 

But, we find that node A.3 has already been visited 
by the SETUP message (this is known to node A.I). 
SETUP is changed to the RETRACE message and the 
DTL is changed as follows: 

(A.3, A,5) pointer 1 
(A, B) pointer 1 

The RETRACE message is forwarded to node A. 

1 .4 which forwards it to A.4.4 and then to A.3.2. Now, 
the first entry on the top of the stack matches the ances- 
tor ID of node A.3.2. The path to peer-group A.5 is com- 
puted. For the sake of this example, let the path go 
through A.3.1 and A 3 4. The DTL for this path is: 

(A.3.2, A.3.1, A. 3. 4) pointer 1 
(A.3, A.5) pointer 1 
(A, B) pointer 1 

Since A.3.4 is already visited by the SETUP mes- 
sage, the SETUP message is changed to a RETRACE 



message. The DTL is changed to: 

(A.3.4) pointer 1 
(A.3, A.5) pointer 1 
5 (A, B) pointer 1 

The RETRACE message is fonwarded to the node 
from which node A.3.2 received the SETUP message 
(node A.3. 1 ). From node A. 3. 1 , the RETRACE message 

'0 is forwarded to A.3.4. Now, the first entry on top of the 
stack matches the node ID. So, a path to peer-group A. 
5 is computed The message is changed to SETUP 
since there are no more visited nodes. The SETUP mes- 
sage is now forwarded to node A.5.1. A.5.1 is a core 

15 node and the DTL stack is not empty. So, the path to 
peer-group B is computed. The SETUP message is then 
forwarded to node A.5.4 and then to node B.I .3. 

Since node B.I. 3 is an ingress node, it computes 
the path to Its core node (node B.1.1). When B.1.1 re- 

20 ceives the SETUP message, it is already active ( on the 
multicast tree). So, it sends a CONNECT message to- 
wards the node A.3.4. This message passes through all 
the links on which the resources were reserved. When 
the message reaches node A.3.4, the connection is es- 

25 tablished. 

The signaling mechanism of the present invention 
Is advantageous in that loop-free connections are cre- 
ated when a new node joins the multicast tree. For proof 
of the instant assertion, considera particular peer-group 

30 at the lowest level. Paths are added to the DTL only un- 
der the following circumstances: 

(i) A SETUP message reaches the ingress node. 
Since the ingress node is the only visited node in 

35 the peer-group at this stage, any path added to the 
DTL cannot create a loop. 

(ii) A SETUP message reaches the core node. 

If the added path has a visited node, a RETRACE 
40 message is forwarded on the reverse path till the 
visited node is reached. This eliminates the possi- 
bility of a loop being created. 

(Ill) A RETRACE message reaches the egress 
45 node. 

If the added path has a visited node, a RETRACE 
message Is forwarded on the reverse path till the 
visited node is reached. This eliminates the possi- 
bility of a loop being created. 

50 

As can be seen, none of the above conditions cre- 
ate a loop. Since this argument can be recursively ex- 
tended to all levels of the hierarchy the signaling mech- 
anism thus ensures that the established connection is 
55 loop-free. As would be understood, similar mechanisms 
can be used for deleting a node from the multicast tree. 

An attractive feature of present invention multicast 
routing scheme is its simplicity. Since nodes at each lev- 
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el follow the same algorithm, the invention is very easy 
to implement. Very little information about the member- 
ship to multicast groups is required to determine a path. 
Only the list of core nodes of the peer-group and its an- 
cestors is flooded within a peer-group. Therefore, there 
is minimal overfiead with the implementation. 

A perceived disadvantage to the present invention 
is that the signaling mechanism involves different mes- 
sage types and appears somewhat complicated. Also, 
the condition that active core nodes have to be a part of 
the multicast tree can result in skewed trees, wherein 
skewed trees lead to waste in bandwidth. This happens 
when there are very few participant nodes and the core 
nodes are far from the participant nodes. The signaling 
mechanism of the present invention, however, ensures 
that there are no loops whenever a node joins an already 
existing multicast tree. Moreover, the cost of the tree 
generated by this algorithm is not far off from the cost 
of the pseudo-optimal tree generated by Steiner heuris- 
tics, and the tree satisfies the property that all nodes 
with degree 1 are either destination nodes or core 
nodes. 

From the above, It should be understood that the 
embodiments described, in regard to the drawings, are 
merely exemplary and that a person skilled in the art 
may make variations and modifications to the shown 
embodiments without departing from the scope of the 
invention as defined in the appended claims. 



wherein said cells are able to be efficiently mul- 
ticast by way of said mu Iticast tree to said nodes 
in said multicast group. 

The method of Claim 1 , further including the step of: 
selecting a peer group leader for each of said 
peer groups in said network for aggregating topol- 
ogy information of nodes in said peer group and 
flooding said topology information in higher level 
peer groups, wherein a list of logical core nodes of 
ancestor peer groups is flooded In a peer group by 
each said peer group leader. 

The method of Claim 1 , wherein a core node is ac- 
tive if a participant node is In the same peer group 
to which the core node belongs, and further includ- 
ing requiring all active core nodes of a specific mul- 
ticast group to be part of said multicast tree for said 
specific multicast group. 

The method of Claim 3, further including requiring 

a core node to be part of said multicast tree if an 
Intermediate non-participant node on the multicast 
tree belongs to that same peer group. 

The method of Claim 4, further including pruning a 
corresponding core node and corresponding Inter- 
mediate nodes from said multicast tree if there is no 
participant node In the corresponding peer group. 



Claims 

1 . A method for multicasting cells in a communications 
network, said communications network including a 
plurality of nodes coupled to one another by links, 
said method comprising the steps of 

dividing said communications network into a hi- 
erarchical arrangement of peer groups, where- 
in a peer group Includes at least one of said 
nodes therein; 

building a multicast tree for a multicast group 
which includes all participant nodes, wherein a 
participant node is either a sender or receiver 
of data for said multicast group, said step of 
building Including the steps of: 

selecting core nodes for each of said peer 
groups within said multicast group, where- 
in a node wanting to become part of said 
multicast group must register with said 
core node in its peer group; 
flooding core node information locally with- 
in each of said peer groups, wherein said 
nodes of a peer group need only maintain 
information about said core nodes of direct 
ancestor peer groups; and 



The method of Claim 2, wherein said topology in- 
formation includes node and link state information. 

A shared communications network for multicasting 
cells, said communications network including a plu- 
rality of nodes coupled to one another by links, said 
network comprising: 

a hierarchical arrangement of peer groups 
making up said communications network, 
wherein a peer group includes at least one of 
said nodes therein; 

one or more multicast trees for a multicast 
group included within said hierarchical arrange- 
ment, which multicast trees includes all partic- 
ipant nodes, wherein a participant node is ei- 
ther a sender or receiver of data for said multi- 
cast group; 

a core node selected for each of said peer 
groups within said multicast group, wherein a 
node wanting to become part of said multicast 
group must register with said core node in its 
peer group, wherein core node information Is 
flooded locally within each of said peer groups, 
and said nodes of a peer group need only main- 
tain information about said core nodes of direct 
ancestor peer groups; and 
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wherein said cells are able to be efficiently multicast 
by way of said multicast tree to said nodes in said 
multicast group. 

The network of Claim 7, further including: s 

a peer group leader for each of said peer 
groups in said network for aggregating topology in- 
formation of nodes in said peer group and flooding 
said topology information in higher level peer 
groups, wherein a list of logical core nodes of an- io 
cestor peer groups is flooded in a peer group by 
each said peer group leader. 
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